# Microprogramación

Ing. Ronald Caravaca Mora

IF4000 - Arquitectura de Computadores Informática Empresarial

31 de octubre de 2021



- Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
- 4 Modelo de programación

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
- 4 Modelo de programación

## Arquitectura de un Microprocesador

La estructura básica de un central processing unit (CPU) computador, sea de propósito general o específico, contiene cuatro bloques funcionales:

- CPU
- Memoria
- Buses
- **4** I/O



Registros

LA CPU controla la ejecución de las instrucciones, el acceso a la memoria y los periféricos, ejecuta operaciones aritméticas y lógicas v controla el manejo de las interrupciones. La CPU contiene una ALU, una unidad de Control, un conjunto de registros internos, componentes de temporización y los buses de conexión internos y externos.

000000

La memoria guarda dos tipos de información: las instrucciones, que son el tipo de operaciones que el computador ejecuta y los datos que son los valores numéricos necesarios para ejecutar las instrucciones. Algunas arquitecturas almacenan toda la información, instrucciones y datos, en una sola memoria, arquitectura es conocida como von Newmann. Otros arquitecturas almacenan las instrucciones en una memoria separada de los datos y esta arquitectura es conocida como Hardvard.

## Arquitectura de un Microprocesador

Los periféricos se utilizan para transferir información desde y hacia la CPU. Los periféricos son, por ejemplo, el teclado, el mouse, la impresora, el monitor, el micrófono, la cámara, etc. De manera mas específica los periféricos son los componentes electrónicos que permiten a la CPU comunicarse con los dispositivos externos.

## Arquitectura de un Microprocesador

Los buses son las rutas de conexión de las diferentes partes de un computador. En este sentido los buses son las conexiones físicas entre la CPU, la memoria y los dispositivos periféricos. Existen tres tipos de buses principales:

- Bus de datos
- Bus de direcciones
- Bus de control

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
- 4 Modelo de programación

## Microarquitectura

Una microarquitectura es la lógica digital que permite ejecutar un conjunto de instrucciones. Es la implementación combinada de registros, memoria, unidades aritméticas lógicas, buses y cualquier otro bloque lógico digital. Todo esto, en conjunto, forma el procesador.

Una microarquitectura combinada con un conjunto de instrucciones (ISA) y el modelo de programación, constituye la arquitectura del computador en su conjunto.

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
  - Contador de programa Acumuladores Registro de status Puntero de pila
- 4 Modelo de programación

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
  Contador de programa

Acumuladores Registro de status Puntero de pila

4 Modelo de programación

Registros

000000000

Este registro sigue la ejecución del programa. Al final de la ejecución de cada instrucción, el contador de programa PC (del inglés "Program Counter"), contiene la dirección de la localización de memoria que almacena la próxima instrucción del programa. El contador de programa se va incrementando durante la ejecución de la instrucción. Finalmente, el PC contiene la dirección que apunta a la siguiente instrucción a ejecutarse. En algunos casos, el contenido de PC puede ser cambiado por el mismo programa. En esta forma se transfiere la ejecución a otra sección del programa.





- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros

Contador de programa

Acumuladores

Registro de status Puntero de pila

4 Modelo de programación

Registros

0000000000

#### Acumuladores

Los acumuladores, son los registros principales para la manipulación de datos. Estos registros tiene la función de almacenar el resultado de operaciones lógicas y aritméticas, calculadas en la ALU, que involucran uno o dos operandos a la vez. En muchas de las arquitecturas, uno de los operandos proviene de un acumulador y el segundo de la localización de memoria especificada por la instrucción. El resultado de la operación se mantiene usualmente en un acumulador. El computador puede probar el resultado en el acumulador para determinar si contiene alguna condición especial, por ejemplo si es cero, negativo, positivo etc. y tomar diferentes decisiones basado en el resultado de la prueba.

- Arquitectura de un Microprocesador
- 3 Registros

  - Registro de status
- 4 Modelo de programación

Este registro tiene la función de almacenar informaciones importantes para la programación, generalmente referentes al contenido de un acumulador o al estado de la CPU.

Por ejemplo, se puede tener un registro de status S, formado por cinco flip flops, cuatro de los cuales retienen información acerca del resultado de la ultima operación con el acumulador A, y el restante se utiliza para memorizar una acción de control pertinente a la CPU. Los primeros cuatro son, los flip flops de: signo, N; rebase, V; cero, Z y acarreo, C. El último se llama flip-flop de inhibición de interrupción l.

Registros

0000000000

Arquitectura de un Microprocesador

# Registro de status



- Arquitectura de un Microprocesador
- 3 Registros

Puntero de pila

4 Modelo de programación

## Puntero de pila

Es el encargado de direccionar una zona especial de la memoria denominada pila. La pila es un conjunto bien definido de posiciones de memoria, en la cual los datos entran (se apilan) y salen (se desapilan), siguiendo la regla EL ULTIMO QUE ENTRA ES EL PRIMERO QUE SALE. En inglés se le conoce como "stack la regla es "Last In First Out.º LIFO. Su función primordial es la de servir como medio para almacenar la dirección de retorno después de la ejecución de una subrutina.

- Arquitectura de un Microprocesador
- 2 Microarquitectura
- 4 Modelo de programación
  - Clasificación Mnemotécnica

## Modelo de programación

El programa de un computador, está compuesto de un número dado de instrucciones elementales ordenadas en una secuencia determinada. por el programador. Cada instrucción elemental o básica, realiza una operación tal como SUME, MULTIPLIQUE o ALMACENE.

Para hacer programas con instrucciones elementales no es necesario conocer en detalle la estructura interna de la máquina. Sin embargo, es necesario conocer su organización lógica básica y distinguir las partes de la máquina que son accesibles al programador.

A las partes de la máquina que están directamente ligadas a la programación se les denomina modelo de programación. Estas son: memoria, contador de programa, acumulador, registro de status y puntero de pila.



## Ejemplo de un programa

Se desea hacer un programa sencillo para sumar los contenidos de las localizaciones número 300, 301 y 302. Las instrucciones que se utilizan para realizar este programa son las siguientes:

- HLT: Esta instrucción hace que se detenga la ejecución del programa.
- ADD XXXX: Esta instrucción suma el contenido de la localización de memoria con dirección XXXX, al contenido del acumulador A. El resultado queda en el acumulador.
- CLA: Esta instrucción pone en cero al contenido del acumulador

## Ejemplo de un programa

Arquitectura de un Microprocesador

| Localización                                | Contenido                       | 4 . 0            |
|---------------------------------------------|---------------------------------|------------------|
| 200<br>201-203<br>204-206<br>207-209<br>210 | CLA ADD 300 ADD 301 ADD 302 HLT | A = 15<br>A = 37 |
| 300<br>301<br>302                           | 15<br>22<br>08                  | A = 45           |

- Arquitectura de un Microprocesador
- 2 Microarquitectura
- 4 Modelo de programación Codificación

Clasificación Mnemotécnica

#### Codificación

En un computador digital, todas las operaciones se realizan en el sistema de números binarios. Sin embargo, durante el procedimiento de escritura de un programa, las instrucciones se pueden expresar en una forma que sea más manejable para el programador. A este cambio de representación de las instrucciones, se le llama CODIFICACION. En general, las instrucciones se pueden codificar en cuatro formas distintas, a saber: BINARIA, OCTAL, HEXADECIMAL, MNEMONICA.

## Codificación binaria

| Localización  | Contenido |  |
|---------------|-----------|--|
|               |           |  |
| %000011001000 | %000101   |  |
| %000011001001 | %010001   |  |
| %000011001010 | %101100   |  |
| %000011001011 | %000100   |  |
| %000011001100 | %010001   |  |
| %000011001101 | %101101   |  |

## Codificación octal

| Localización | Contenido |  |
|--------------|-----------|--|
|              |           |  |
| @0310        | @05       |  |
| @0311        | @21       |  |
| @0312        | @54       |  |
| @0313        | @04       |  |
| @0314        | @21       |  |
| @0315        | @55       |  |
| @0316        | @04       |  |

## Codificación hexadecimal

| Localización | Contenido |  |
|--------------|-----------|--|
|              |           |  |
| \$0C8        | \$05      |  |
| \$0C9        | \$11      |  |
| \$0CA        | \$2C      |  |
| \$0CB        | \$04      |  |
| \$0CC        | \$11      |  |
| \$0CD        | \$2D      |  |
| \$0CE        | \$04      |  |

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
- 4 Modelo de programación

Codificación

Clasificación Mnemotécnica

Clasificación de las instrucciones

#### Codificación Mnemotécnica



| Codificación | Operación | Dirección     |  |
|--------------|-----------|---------------|--|
|              |           |               |  |
| Binaria      | %010001   | %101000000111 |  |
| Octal        | @21       | @5007         |  |
| Hexadecimal  | \$11      | \$A07         |  |
| Mnemónica    | ADD       | DATO          |  |
|              |           |               |  |

DATO se define igual a \$A07 en otra sección del programa.

### Codificación Mnemotécnica

La codificación simbólica es muy conveniente para el programador, pero no puede ser entendida por el computador. El único lenguaje que puede entender el computador es la codificación binaria. Por esto es necesario hacer la traducción al equivalente binario, en una de las dos formas siguientes:

- Manualmente, empleando tablas con el mnemotécnico y el código binario equivalente.
- Mediante un programa de computador especial llamado ENSAMBLADOR ("assembler").

#### Codificación Mnemotécnica

A un programa especificado así, se le llama PROGRAMA FUEN-TE. El ensamblador compara cada instrucción mnemotécnica con una tabla de instrucciones y las reemplaza con el código binario equivalente. También determinará la dirección correspondiente a cada etiqueta mediante un contador propio del ensamblador, que se inicia en la primera posición del programa traducido. A este proceso de traducción se le llama ENSAMBLAJE DEL PROGRAMA y el resultado de este proceso se denomina PROGRAMA OBJETO.

- 1 Arquitectura de un Microprocesador
- 2 Microarquitectura
- 3 Registros
- 4 Modelo de programación

Clasificación Mnemotécnica

Clasificación de las instrucciones

#### Clasificación de las instrucciones

Los computadores contienen una gran variedad de instrucciones determinadas según el diseño de la CPU. Para facilitar el estudio de las mismas, generalmente se clasifican de diferentes formas. Una manera de clasificar las instrucciones se basa en la parte del computador a la que se refiere la instrucción. Empleando este procedimiento se obtienen los siguientes tipos:

- 1 Instrucciones de Referencia a Memoria.
- 2 Instrucciones de Referencia a Registros.
- 3 Instrucciones de Referencia a E/S.

#### Clasificación de las instrucciones

Otro modo de clasificar las instrucciones se basa en la función que realiza cada instrucción:

- 1 Movimiento de datos, instrucciones lógicas y aritméticas.
- Instrucciones de control.
- 3 Instrucciones de subrutina.
- 4 Instrucciones de referencia a registros.
- Instrucciones de E/S.

## Ejemplo de set de instrucciones

| Tipo<br>de<br>Instrucción | Mnemo-<br>técnico | Número<br>de<br>palabras | Operación realizada     | Banderas<br>alteradas |
|---------------------------|-------------------|--------------------------|-------------------------|-----------------------|
| Movimiento                | LDA               | 2.3                      | A ? (M)                 | N 2 -                 |
| de Datos.                 | STA               | 3                        | M ? (A)                 |                       |
| Aritméticas               | ADD               | 2,3                      | A ? (A) + (M)           | NV-ZC                 |
| v Lógicas                 | SUB               | 2,3                      | A ? (A) - (M)           | NV-ZC                 |
| ,                         | AND               | 2.3                      | A? (A) ? 3M)            | N Z -                 |
|                           | ORA               | 2,3                      | A? (A) ? (M)            | N Z -                 |
|                           | PHA               | 1                        | (A) ?                   |                       |
|                           | PLA               | 1                        | ? A                     | N Z -                 |
| Control                   | HLT               | - i                      | Detenga la CPUCR ? DI   |                       |
|                           | NOP               | 1                        | Operación nula ? DI+1   |                       |
|                           | PHS               | 1                        | (S) ?                   |                       |
|                           | PLS               | 1                        | ? S                     | NVIZC                 |
|                           | RTI               | 1                        | ? PC; I ? 0; ? (PC)     | N V I Z C             |
|                           | JMP               | 3                        | ? M                     |                       |
|                           | BEO               | 2                        | (Z)=1 ? M; (Z)=0 ? DI+2 |                       |
|                           | BNE               | 2                        | (Z)=0 ? M; (Z)=1 ? DI+2 |                       |
|                           | BCS               | 2                        | (C)=1 ? M; (C)=0 ? DI+2 |                       |
|                           | BCC               | 2                        | (C)=0 ? M; (C)=1 ? DI+2 |                       |
|                           | BPL               | 2                        | (N)=0 ? M; (N)=1 ? DI+2 |                       |
|                           | BMI               | 2                        | (N)=1 ? M; (N)=0 ? DI+2 |                       |
|                           | BVS               | 2                        | (V)=1 ? M; (V)=0 ? DI+2 |                       |
|                           | BVC               | 2                        | (V)=0 ? M; (V)=1 ? DI+2 |                       |
| Subrutina                 | JSR               | 3                        | DI+3 ?; ? M             |                       |
|                           | RTS               | 1                        | ? PC; ? (PC)            |                       |
| Referencia                | CLA               | 1                        | A ? 00                  | N Z -                 |
| a                         | CPA               | 1                        | A ? (A)                 | N Z -                 |
| Registros                 | INA               | 1                        | A ? (A) + 1             | NV-ZC                 |
|                           | DCA               | 1                        | A ? (A) - 1             | NV-ZC                 |
|                           | ROL               | 1                        | A ? A4A0,C; C ? A5      | N Z C                 |
| T.<br>T.                  | ROR               | 1                        | A ? C,A5A1; C ? A0      | N··ZC                 |
|                           | TAP               | 1                        | P ? (A)                 |                       |
|                           | TPA               | 1                        | A ? (P)                 | N Z -                 |
|                           | SEC               | 1                        | C? 1                    | c                     |
|                           | CLC               | 1                        | C? 0                    | c                     |
|                           | SEI               | 1                        | 1? 1<br>1? 0            | I                     |
|                           | TNP               | 2                        | A ? (PUERTO)            | N Z -                 |
| Entrada/                  |                   |                          |                         |                       |

DEBO=ACARREO Si C=1, no ha ocurrido un debo.

